From: Jacob Pan Date: Wed, 3 Aug 2016 12:41:13 +0000 (+0200) Subject: mwait-idle: add Denverton X-Git-Tag: archive/raspbian/4.8.0-1+rpi1~1^2~638 X-Git-Url: https://dgit.raspbian.org/%22http://www.example.com/cgi/success//%22http:/www.example.com/cgi/success/?a=commitdiff_plain;h=a33c2a9a7831587b7648baeb1249e8c6975f5b35;p=xen.git mwait-idle: add Denverton Denverton is an Intel Atom based micro server which shares the same Goldmont architecture as Broxton. The available C-states on Denverton is a subset of Broxton with only C1, C1e, and C6. Signed-off-by: Jacob Pan Signed-off-by: Len Brown Signed-off-by: Rafael J. Wysocki [Linux commit: 0080d65b7719fc58e60b5595fc61acded330004f] Signed-off-by: Jan Beulich Acked-by: Andrew Cooper --- diff --git a/xen/arch/x86/cpu/mwait-idle.c b/xen/arch/x86/cpu/mwait-idle.c index 27361f90c7..290c57baa3 100644 --- a/xen/arch/x86/cpu/mwait-idle.c +++ b/xen/arch/x86/cpu/mwait-idle.c @@ -658,6 +658,28 @@ static struct cpuidle_state bxt_cstates[] = { {} }; +static const struct cpuidle_state dnv_cstates[] = { + { + .name = "C1-DNV", + .flags = MWAIT2flg(0x00), + .exit_latency = 2, + .target_residency = 2, + }, + { + .name = "C1E-DNV", + .flags = MWAIT2flg(0x01), + .exit_latency = 10, + .target_residency = 20, + }, + { + .name = "C6-DNV", + .flags = MWAIT2flg(0x20) | CPUIDLE_FLAG_TLB_FLUSHED, + .exit_latency = 50, + .target_residency = 500, + }, + {} +}; + static void mwait_idle(void) { unsigned int cpu = smp_processor_id(); @@ -844,6 +866,11 @@ static const struct idle_cpu idle_cpu_bxt = { .disable_promotion_to_c1e = 1, }; +static const struct idle_cpu idle_cpu_dnv = { + .state_table = dnv_cstates, + .disable_promotion_to_c1e = 1, +}; + #define ICPU(model, cpu) \ { X86_VENDOR_INTEL, 6, model, X86_FEATURE_MONITOR, \ &idle_cpu_##cpu} @@ -881,6 +908,7 @@ static const struct x86_cpu_id intel_idle_ids[] __initconstrel = { ICPU(0x55, skx), ICPU(0x57, knl), ICPU(0x5c, bxt), + ICPU(0x5f, dnv), {} };